Docker

您所在的位置:网站首页 docker compose user Docker

Docker

2023-03-26 03:22| 来源: 网络整理| 查看: 265

Just specify a path and let the Engine create a volumeSpecify an absolute path mappingPath on the host, relative to the Compose fileUser-relative pathNamed volume

服务 ( service ):一个应用容器,实际上可以运行多个相同镜像的实例

项目 ( project ):由一组关联的应用容器组成的一个完整业务单元。

可见,一个项目可以由多个服务(容器)关联而成, Compose 面向项目进行管理

docker build 构建或重新构建服务。服务被构建后将会以project_service 的形式标记,例如:composetest_dbdocker-compose up -d 构建、创建、重新创建、启动,连接服务的相关容器。所有连接的服务都会启动,除非它们已经运行。-d后台运行docker-compose help build 查看docker-compose build的帮助docker-compose kill -s SIGINTdocker-compose logs 查看服务的日志输出docker-compose port eureka 8761 输出eureka服务8761端口所绑定的公共端口docker-compose ps eureka 列出指定容器,默认所有容器docker-compose pulldocker-compose rm eurekadocker-compose run web bash 启动一个web服务,同时执行bashdocker-compose scale user=3 movie=3 设置指定服务运行容器的个数,以service=num的形式指定docker-compose start eureka 启动指定服务已存在的容器docker-compose stop eureka 停止已运行的容器 from flask import Flaskfrom redis import Redisapp=Flask(__name__)redis =Redis(host='redis',port=6379)@app.route('/')def hello(): count=redis.incr('hits') return 'Hello World! 该页面已被访问{}次.\n'.format(count)if __name__=="main": app.run(host="0.0.0.0",debug=True)

docker-compose.yml常用命令 docker-compose.yml是Compose的默认模板文件。该文件有多种写法,例如Version 1 file format、Version 2 file format、Version 2.1 file format、Version 3 file format等。其中,Version 1 file format将逐步被被弃用;Version 2.x及Version 3.x基本兼容,是未来的趋势。考虑到目前业界的使用情况,本节只讨论Version 2 file format下的常用命令。

(1) build 配置构建时的选项,Compose会利用它自动构建镜像。build的值可以是一个路径,例如:

build: ./dir 也可以是一个对象,用于指定Dockerfile和参数,例如:

build: context: ./dir dockerfile: Dockerfile-alternate args: buildno: 1 (2) command 覆盖容器启动后默认执行的命令。示例:

command: bundle exec thin -p 3000 也可以是一个list,类似于Dockerfile中的CMD指令,格式如下:

command: [bundle, exec, thin, -p, 3000] (3) dns 配置dns服务器。可以是一个值,也可以是一个列表。示例:

dns: 8.8.8.8 dns:

8.8.8.89.9.9.9 (4) dns_search 配置DNS的搜索域名,可以是一个值,也可以是一个列表。示例:

dns_search: example.com dns_search:

dc1.example.comdc2.example.com (5) environment 环境变量设置,可使用数组或字典两种方式。示例:

environment: RACK_ENV: development SHOW: ‘true’ SESSION_SECRET: environment:

RACK_ENV=developmentSHOW=trueSESSION_SECRET (6) env_file 从文件中获取环境变量,可指定一个文件路径或路径列表。如果通过 docker-compose -f FILE 指定了Compose文件,那么env_file中的路径是Compose文件所在目录的相对路径。使用environment指定的环境变量会覆盖env_file指定的环境变量。示例:

env_file: .env env_file:

./common.env # 共用./apps/web.env # web用/opt/secrets.env # 密码用 (7) expose 暴露端口,只将端口暴露给连接的服务,而不暴露给宿主机。示例:

expose:

“3000”“8000” (8) external_links 连接到docker-compose.yml外部的容器,甚至并非Compose管理的容器,特别是提供共享或公共服务的容器。格式跟links类似,例如:

external_links:

redis_1project_db_1:mysqlproject_db_1:postgresql (9) image 指定镜像名称或镜像id,如果本地不存在该镜像,Compose会尝试下载该镜像。

示例:

image: java (10) links 连接到其他服务的容器。可以指定服务名称和服务别名( SERVICE:ALIAS ),也可只指定服务名称。例如:

web: links:

dbdb:databaseredis (11) networks 详见本书《Docker Compose网络设置》一节。

(12) network_mode 设置网络模式。示例:

network_mode: “bridge” network_mode: “host” network_mode: “none” network_mode: “service:[service name]” network_mode: “container:[container name/id]” (13) ports 暴露端口信息,可使用HOST:CONTAINER 的格式,也可只指定容器端口(此时宿主机将会随机选择端口),类似于docker run -p 。

需要注意的是,当使用HOST:CONTAINER 格式映射端口时,容器端口小于60将会得到错误的接口,因为yaml会把xx:yy 的数字解析为60进制。因此,建议使用字符串的形式。示例:

ports:

“3000”“3000-3005”“8000:8000”“9090-9091:8080-8081”“49100:22”“127.0.0.1:8001:8001”“127.0.0.1:5000-5010:5000-5010” (14) volumes 卷挂载路径设置。可以设置宿主机路径 (HOST:CONTAINER) ,也可指定访问模式 (HOST:CONTAINER:ro)。示例:

volumes:

Just specify a path and let the Engine create a volume /var/lib/mysql

Specify an absolute path mapping /opt/data:/var/lib/mysql

Path on the host, relative to the Compose file ./cache:/tmp/cache

User-relative path ~/configs:/etc/configs/:ro

Named volume datavolume:/var/lib/mysql (15) volumes_from 从另一个服务或容器挂载卷。可指定只读(ro)或读写(rw),默认是读写(rw)。示例:

volumes_from:

service_nameservice_name:rocontainer:container_namecontainer:container_name:rw TIPS (1) docker-compose.yml还有很多其他命令,比如depends_on、pid、devices等。限于篇幅,笔者仅挑选常用的命令进行讲解,其他命令不作赘述。感兴趣的读者们可参考官方文档:https://docs.docker.com/compose/compose-file/ 。

瓦雀



【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3